Doxygen is a documentation system for C++, C, Java, Objective-C, IDL
(Corba and Microsoft flavors) and to some extent PHP, C# and D.

It can generate an on-line documentation browser (in HTML) and/or an
off-line reference manual (in $\mbox{\LaTeX}$ ) from a set of documented
source files. There is also support for generating output in RTF
(MS-Word), PostScript, hyperlinked PDF, compressed HTML, and Unix man
pages. The documentation is extracted directly from the sources, which
makes it much easier to keep the documentation consistent with the
source code.

You can configure doxygen to extract the code structure from
undocumented source files. This is very useful to quickly find your way
in large source distributions. You can also visualize the relations
between the various elements by means of include dependency graphs,
inheritance diagrams, and collaboration diagrams, which are all
generated automatically.

To take full advantage of doxygen's features the following additional
ports should be installed:

 - print/texlive for generating LaTeX, Postscript, and PDF output.
 - math/graphviz for the include dependency graphs, the graphical
   inheritance graphs, and the collaboration graphs.
 - print/ghostscript

Flavors:
        * gui -- build Qt frontend

Note:

When generating certain filenames (for example directory listing with
the html backend), doxygen uses an md5 sum of the source path.  This
is a problem for the ports framework, as the sources location can vary
(/usr/obj/ports/..., usr/ports/.../w-..., /usr/ports/mystuff/.../w-...).

This port has been modified so that when running doxygen, the
DOXYGEN_ENCODE_PATH_STRIP environment variable can be set to a prefix
to be stripped from a path before its md5 sum is calculated.  Ports
using doxygen should use "DOXYGEN_ENCODE_PATH_STRIP=${WRKSRC}".
